@use 'variables' as *;
// 导入后台样式
@forward './admin/animations.scss';
// 导入前台样式
@forward './frontend/animations.scss';
@forward 'reset';
@forward 'layout';
@forward 'components';
@forward 'utils';

// 默认主题变量 - 改为现代亮色风格
:root {
  // 主色调
  --primary-color: #1677ff;
  --success-color: #52c41a;
  --warning-color: #faad14;
  --danger-color: #ff4d4f;
  --info-color: #909399;

  // 文本颜色
  --text-color: #1f2329;
  --text-color-secondary: #646a73;
  --heading-color: #1f2329;

  // 背景和边框
  --border-color: #e5e6eb;
  --bg-color: #ffffff;
  --bg-color-secondary: #f5f7fa;
  --bg-color-overlay: #ffffff;

  // 后台特定样式
  --menu-bg-color: #ffffff;
  --menu-text-color: #1f2329;
  --menu-active-bg: #e6f4ff;
  --menu-hover-bg: #f5f5f5;

  // 特效
  --gradient-primary: linear-gradient(45deg, #1677ff, #69b4ff);
  --box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);

  // 布局尺寸
  --header-height: 60px;
  --sidebar-width: 240px;
  --transition-base: all 0.3s ease;

  // 后台管理样式变量
  --admin-primary: #1677ff;
  --admin-success: #52c41a;
  --admin-warning: #faad14;
  --admin-danger: #ff4d4f;
  --admin-info: #909399;

  --admin-text: #1f2329;
  --admin-text-secondary: #646a73;

  --admin-bg: #ffffff;
  --admin-bg-secondary: #f5f7fa;
  --admin-border: #e5e6eb;

  --admin-menu-bg: #ffffff;
  --admin-menu-text: #1f2329;
  --admin-menu-active: #1677ff;
  --admin-menu-hover: #f0f5ff;

  --admin-header-height: 60px;
  --admin-sidebar-width: 240px;
}

// 全局样式
:root {
  scroll-behavior: smooth;
  font-size: 16px;

  @media screen and (max-width: 768px) {
    font-size: 14px;
  }

  @media screen and (max-width: 480px) {
    font-size: 12px;
  }
}

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial,
    sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  margin: 0;
}

// Element Plus 全局样式覆盖
.el-menu {
  border-right: none !important;
  --el-menu-bg-color: transparent !important;
  --el-menu-text-color: var(--text-color) !important;
  --el-menu-hover-bg-color: var(--menu-hover-bg) !important;
  --el-menu-active-color: var(--primary-color) !important;
  --el-menu-item-height: 50px !important;
}

.el-menu--horizontal {
  border-bottom: none !important;
}

.el-card {
  --el-card-bg-color: var(--bg-color) !important;
  --el-card-border-color: var(--border-color) !important;
  background-color: var(--bg-color) !important;
  border-color: var(--border-color) !important;
  color: var(--text-color) !important;

  .el-card__header {
    border-bottom: 1px solid var(--border-color) !important;
    padding: 0.875rem 1rem !important;
    background-color: var(--bg-color) !important;
    color: var(--text-color) !important;
  }

  .el-card__body {
    padding: 1rem !important;
    background-color: var(--bg-color) !important;
    color: var(--text-color) !important;
  }
}

.el-dialog {
  --el-dialog-bg-color: var(--bg-color) !important;
  --el-dialog-border-color: var(--border-color) !important;
  border-radius: 0.5rem !important;

  .el-dialog__header {
    margin: 0 !important;
    padding: 0.875rem 1rem !important;
    border-bottom: 1px solid var(--border-color);
    background-color: var(--bg-color) !important;
    color: var(--text-color) !important;
  }

  .el-dialog__body {
    padding: 1rem !important;
    background-color: var(--bg-color) !important;
    color: var(--text-color) !important;
  }

  .el-dialog__footer {
    padding: 0.875rem 1rem !important;
    border-top: 1px solid var(--border-color);
    background-color: var(--bg-color) !important;
  }
}

.el-form {
  .el-form-item {
    margin-bottom: 1rem !important;

    .el-form-item__label {
      color: var(--text-color) !important;
    }
  }
}

.el-table {
  --el-table-bg-color: var(--bg-color) !important;
  --el-table-tr-bg-color: var(--bg-color) !important;
  --el-table-header-bg-color: var(--bg-color-secondary) !important;
  --el-table-border-color: var(--border-color) !important;
  --el-table-text-color: var(--text-color) !important;
  --el-table-header-text-color: var(--text-color) !important;
  background-color: var(--bg-color) !important;
  color: var(--text-color) !important;

  th.el-table__cell {
    background-color: var(--bg-color-secondary) !important;
    color: var(--text-color) !important;
    border-bottom: 1px solid var(--border-color) !important;
  }

  td.el-table__cell {
    background-color: var(--bg-color) !important;
    color: var(--text-color) !important;
    border-bottom: 1px solid var(--border-color) !important;
  }
}

// 滚动条样式
::-webkit-scrollbar {
  width: 0.375rem;
  height: 0.375rem;
}

::-webkit-scrollbar-track {
  background: var(--bg-color-secondary);
  border-radius: $radius-full;
}

::-webkit-scrollbar-thumb {
  background: var(--border-color);
  border-radius: $radius-full;

  &:hover {
    background: var(--primary-color);
  }
}

// Element Plus 组件主题适配
.el-button {
  --el-button-bg-color: var(--primary-color) !important;
  --el-button-border-color: var(--primary-color) !important;
  --el-button-hover-bg-color: var(--primary-color) !important;
  --el-button-hover-border-color: var(--primary-color) !important;
  --el-button-active-bg-color: var(--primary-color) !important;
  --el-button-active-border-color: var(--primary-color) !important;

  &--text {
    color: var(--text-color) !important;

    &:hover {
      color: var(--primary-color) !important;
    }
  }
}

.el-input {
  --el-input-bg-color: var(--bg-color) !important;
  --el-input-border-color: var(--border-color) !important;
  --el-input-text-color: var(--text-color) !important;
  --el-input-hover-border-color: var(--primary-color) !important;

  .el-input__wrapper {
    background-color: var(--bg-color) !important;
  }
}

// 加载动画主题适配
.el-loading-mask {
  background-color: var(--bg-color-secondary) !important;
  opacity: 0.9 !important;

  .el-loading-spinner {
    .circular {
      stroke: var(--primary-color) !important;
    }

    .el-loading-text {
      color: var(--text-color) !important;
    }
  }
}

// 日期选择器主题适配
.el-date-picker {
  --el-datepicker-bg-color: var(--bg-color) !important;
  --el-datepicker-border-color: var(--border-color) !important;
  --el-datepicker-text-color: var(--text-color) !important;
  --el-datepicker-off-text-color: var(--text-color-secondary) !important;
  --el-datepicker-header-text-color: var(--text-color) !important;
  background-color: var(--bg-color) !important;

  .el-date-picker__header {
    color: var(--text-color) !important;
  }

  .el-date-picker__content {
    background-color: var(--bg-color) !important;
  }

  .el-date-table {
    th {
      color: var(--text-color) !important;
    }

    td {
      &.available:hover {
        color: var(--primary-color) !important;
      }

      &.current:not(.disabled) span {
        background-color: var(--primary-color) !important;
        color: var(--white) !important;
      }
    }
  }
}

// 下拉面板主题适配
.el-popper {
  --el-popup-bg-color: var(--bg-color) !important;
  --el-popup-border-color: var(--border-color) !important;
  background-color: var(--bg-color) !important;
  border-color: var(--border-color) !important;

  .el-popper__arrow::before {
    background-color: var(--bg-color) !important;
    border-color: var(--border-color) !important;
  }
}

// 全局tooltip样式适配
.el-tooltip__popper.is-light {
  --el-text-color-primary: var(--text-color) !important;
  --el-border-color-light: var(--border-color) !important;
  --el-fill-color-light: var(--bg-color) !important;
  --el-fill-color: var(--bg-color) !important;
  --el-bg-color: var(--bg-color) !important;
  color: var(--text-color) !important;
  background: var(--bg-color) !important;
  border-color: var(--border-color) !important;
  box-shadow: 0 3px 6px -4px rgba(0, 0, 0, 0.12), 0 6px 16px 0 rgba(0, 0, 0, 0.08), 0 9px 28px 8px rgba(0, 0, 0, 0.05) !important;
}